// Copyright 2022 a.o.smith ALL Rights Reserved
package com.liuxinlong.modules.assets.service;

import com.liuxinlong.common.ImportResp;
import com.liuxinlong.modules.assets.dto.ImportAssetsBudgetDto;
import com.liuxinlong.modules.entity.AssetsBudget;
import com.liuxinlong.modules.entity.AssetsBudgetYear;
import com.liuxinlong.modules.entity.AssetsMonthDetail;
import com.liuxinlong.modules.entity.AssetsSettlement;

import javax.servlet.http.HttpServletResponse;
import java.util.List;
import java.util.Map;

/**
 * 固资预算业务接口层
 *
 * @author liuxinlong@hotwater.com.cn
 * @version 1.0.0
 * @since 2023-10-27
 */
public interface AssetsBudgetService {
    /**
     * 查询固资预算列表
     *
     * @param queryParam 查询参数
     * @return 固资预算列表
     */
    Map<String, Object> pageAssetsBudget(Map<String, Object> queryParam);

    /**
     * 获取固资预算数量
     *
     * @param queryParam 查询参数
     * @return 固资预算数量
     */
    int getAssetsBudgetCount(Map<String, Object> queryParam);

    /**
     * 新增固资预算信息
     *
     * @param assetsBudget      固资预算信息
     * @param assetsMonthDetail 月度信息
     */
    void addAssetsBudget(AssetsBudget assetsBudget, AssetsMonthDetail assetsMonthDetail);

    /**
     * 修改固资预算信息
     *
     * @param assetsBudget      固资预算信息
     * @param assetsMonthDetail 月度信息
     */
    void updateAssetsBudget(AssetsBudget assetsBudget, AssetsMonthDetail assetsMonthDetail);

    /**
     * 删除固资预算信息
     *
     * @param id 固资预算信息id
     */
    void deleteAssetsBudget(String id);

    /**
     * 导出固资预算信息
     *
     * @param response response
     */
    void exportAssetsBudget(HttpServletResponse response);

    /**
     * 导入数据预处理
     *
     * @param fileName 文件地址
     * @return 预处理数据
     */
    ImportResp importAssetsBudget(String fileName);

    /**
     * 批量新增固资预算信息
     *
     * @param dataList 固资预算信息列表
     * @return 失败数据
     */
    ImportResp batchAddAssetsBudget(List<ImportAssetsBudgetDto> dataList);

    /**
     * 修改固资预算状态
     *
     * @param id 固资预算信息id
     */
    void updateAssetsBudgetStatus(String id);

    /**
     * 查询固资预算拓展信息
     *
     * @param id 固资预算id
     * @return 固资预算拓展信息
     */
    Map<String, Object> queryAssetsBudgetExpand(String id);

    /**
     * 查询固资年度预算列表
     *
     * @param queryParam 查询参数
     * @return 固资年度预算列表
     */
    List<Map<String, Object>> pageAssetsBudgetYear(Map<String, Object> queryParam);

    /**
     * 获取固资年度预算数量
     *
     * @param queryParam 查询参数
     * @return 固资年度预算数量
     */
    int getAssetsBudgetYearCount(Map<String, Object> queryParam);

    /**
     * 新增固资年度预算信息
     *
     * @param assetsBudgetYear 固资年度预算信息
     */
    void addAssetsBudgetYear(AssetsBudgetYear assetsBudgetYear);

    /**
     * 修改固资年度预算信息
     *
     * @param assetsBudgetYear 固资年度预算信息
     */
    void updateAssetsBudgetYear(AssetsBudgetYear assetsBudgetYear);

    /**
     * 删除固资年度预算信息
     *
     * @param id 固资年度预算信息id
     */
    void deleteAssetsBudgetYear(String id);

    /**
     * 查询固资结算信息列表
     *
     * @param queryParam 查询参数
     * @return 固资结算信息列表
     */
    List<Map<String, Object>> pageAssetsSettlement(Map<String, Object> queryParam);

    /**
     * 获取固资结算信息数量
     *
     * @param queryParam 查询参数
     * @return 固资结算信息数量
     */
    int getAssetsSettlementCount(Map<String, Object> queryParam);

    /**
     * 新增固资结算信息
     *
     * @param assetsSettlement 固资结算信息
     */
    void addAssetsSettlement(AssetsSettlement assetsSettlement);

    /**
     * 修改固资结算信息
     *
     * @param assetsSettlement 固资结算信息
     */
    void updateAssetsSettlement(AssetsSettlement assetsSettlement);

    /**
     * 删除固资结算信息
     *
     * @param id 固资结算信息id
     */
    void deleteAssetsSettlement(String id);
}
